<template>
  <BasicModal
    v-bind="$attrs"
    @register="registerModal"
    :title="displayModuleTitle"
    @ok="onButtonOkClick"
    :width="800"
  >
    <BasicForm @register="registerForm" />
  </BasicModal>
</template>
<script lang="ts">
  import { defineComponent, ref, unref, computed } from 'vue';
  import { BasicModal, useModalInner } from '/@/components/Modal';
  import { BasicForm, useForm } from '/@/components/Form/index';

  import { useMessage } from '/@/hooks/web/useMessage';
  import { OperationTypeEnum } from '/@/enums/appEnum';

  import { QcUnifyTransToChildProps } from '/#/QcUnify';
  import { displayTitle } from '/@/utils/QcUnifyUtil';

  import { apiFilterFormSchema } from './apiFilter.data';

  import { addApiFilter, updateApiFilter, getApiFilter } from '/@/api/platform/apiFilter';

  const { createMessage } = useMessage();

  export default defineComponent({
    name: 'AddOrUpdateProjectUser',
    components: { BasicModal, BasicForm },
    emits: ['success', 'register'],
    setup(_, { emit }) {
      //接收父组件传递过来的数据对象
      const qcUnifyProps = ref<QcUnifyTransToChildProps>();
      /**
       * 处理显示的模块标题，用于显示在弹出框中的标题
       */
      let displayModuleTitle = computed(() => {
        return displayTitle(qcUnifyProps.value);
      });

      const [registerForm, { setFieldsValue, resetFields, validate, updateSchema }] = useForm({
        labelWidth: 120,
        schemas: apiFilterFormSchema,
        showActionButtonGroup: false,
        actionColOptions: {
          span: 24,
        },
      });

      /**
       * 根据父组件传递过来的参数获取对应的操作，操作不同所对应的界面不同
       */
      const [registerModal, { setModalProps, closeModal }] = useModalInner(async (data) => {
        console.log(data);
        //接收父组件传递的数据
        if (data != undefined && data != null) {
          qcUnifyProps.value = unref(data);
          console.log('接收的对象', data.dataId);
        }

        resetFields(); //重置表单
        setModalProps({ confirmLoading: false });

        // 如果是修改数据，根据传入的id获取数据后进行赋值
        if (data.operateType == OperationTypeEnum.EDIT) {
          getById();
          updateSchema({
            field: 'upDateTm',
            show: true,
          });
        } else {
          updateSchema({
            field: 'upDateTm',
            show: false,
          });
        }
      });

      function getById() {
        getApiFilter(qcUnifyProps.value?.dataId)
          .then((res) => {
            console.log('res', res);
            setFieldsValue({
              ...res,
            });
          })
          .catch((ex) => {
            console.log('catch ', ex);
            createMessage.error(ex.msg);
          });
      }

      /**
       * 点击确认按钮，根据不同的op调用对应方法保存信息
       */
      async function onButtonOkClick() {
        //根据指定的操作类型分别进行提交数据和处理
        if (qcUnifyProps.value?.operateType == OperationTypeEnum.ADD) {
          //对应操作的步骤为：验证表单、提交后台保存、关闭modal、调用父组件事件刷新数据
          try {
            const values = await validate();
            setModalProps({ confirmLoading: true });
            //调用接口进行保存
            addApiFilter(values)
              .then((res) => {
                if (!res || Object.keys(res).length == 0) {
                  createMessage.success('保存成功。', 2);
                }
                opSuccess();
              })
              .catch((ex) => {
                console.log('catch ', ex);
                createMessage.error(ex.msg);
              });
          } finally {
            setModalProps({ confirmLoading: false });
          }
        } else if (qcUnifyProps.value?.operateType == OperationTypeEnum.EDIT) {
          const values = await validate();
          setModalProps({ confirmLoading: true });
          //调用接口进行保存
          updateApiFilter(values)
            .then((res) => {
              if (!res || Object.keys(res).length == 0) {
                createMessage.success('修改成功。', 2);
              }
              opSuccess();
            })
            .catch((ex) => {
              console.log('catch ', ex);
              createMessage.error(ex.msg);
            });
        } else {
          createMessage.error('当前操作类型错误，无法进行对应操作。', 5);
        }
      }

      //操作成功后
      function opSuccess() {
        closeModal();
        emit('success');
      }

      return {
        displayModuleTitle,
        registerModal,
        registerForm,
        onButtonOkClick,
        opSuccess,
      };
    },
  });
</script>
